<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org" lang="en">
<head>
    <meta charset="UTF-8">
    <title>供应商管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="stylesheet" th:href="@{/layui/css/layui.css}" media="all"/>
    <link rel="stylesheet" th:href="@{/css/public.css}" media="all"/>
</head>
<body class="childrenBody">
<!--查询条件开始-->
<blockquote class="layui-elem-quote">
    <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">供应商名称</label>
                <div class="layui-input-inline">
                    <input type="text" name="providername" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">联系人</label>
                <div class="layui-input-inline">
                    <input type="text" name="connectionperson" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <div class="layui-input-inline">
                    <button type="button" class="layui-btn" lay-submit="" lay-filter="doSearch"><span
                            class="layui-icon layui-icon-search"></span>查询
                    </button>
                    <button type="reset" class="layui-btn layui-btn-warm"><span
                            class="layui-icon layui-icon-refresh-1"></span>重置
                    </button>
            </div>
        </div>
        </div>
    </form>
</blockquote>
<!--查询条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="providerTable" lay-filter="providerTable"></table>
    <div id="providerToolBar" style="display: none;">
        <button type="button" lay-event="add" class="layui-btn  layui-btn-sm ">
            <span class="layui-icon ">&#xe608;</span>添加供应商
        </button>
        <button type="button" lay-event="batchDelete" class="layui-btn  layui-btn-sm ">
            <span class="layui-icon layui-icon-delete "></span>批量删除
        </button>
    </div>
    <div id="providerRowBar" style="display: none;">
        <button type="button" lay-event="update" class="layui-btn layui-btn-sm  layui-btn-warm">
            <span class="layui-icon layui-icon-edit"></span>修改
        </button>
        <button type="button" lay-event="delete" class="layui-btn layui-btn-sm  layui-btn-danger">
            <span class="layui-icon layui-icon-delete"></span>删除
        </button>

    </div>
</div>
<!--数据表格结束-->

<!--添加和修改的弹出层开始-->
<div style="display: none; padding: 6px" id="addOrUpdateDiv">
    <form action="" method="post" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">供应商名称</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="providername" lay-verify="required" autocomplete="off" placeholder="请输入供应商名称" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">供应商电话</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="telephone" lay-verify="required" autocomplete="off" placeholder="请输入供应商电话" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">邮编</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="zip"  autocomplete="off" placeholder="请输入供应商邮编" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">供应商地址</label>
            <div class="layui-input-block">
                <input type="text" name="address" autocomplete="off" placeholder="请输入供应商地址" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">联系人</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="connectionperson" lay-verify="required" autocomplete="off" placeholder="请输入联系人" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">联系人电话</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="phone" lay-verify="required" autocomplete="off" placeholder="请输入联系人电话" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">邮箱</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="email" lay-verify="required" autocomplete="off" placeholder="请输入供应商邮箱" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">开户银行</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="bank" lay-verify="required" autocomplete="off" placeholder="请输入开户银行" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">帐号</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="account" lay-verify="required" autocomplete="off" placeholder="请输入供应商帐号" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">传真</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="id">
                    <input type="text" name="fax" lay-verify="required" autocomplete="off" placeholder="请输入供应商传真" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">是否可用</label>
                <div class="layui-input-inline">
                    <input type="radio" name="available" value="1" title="可用" checked="">
                    <input type="radio" name="available" value="0" title="不可用" >
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;">
                <button type="button" class="layui-btn" lay-submit="" lay-filter="doSubmit" id="doSubmit" ><span class="layui-icon layui-icon-add-1"></span>提交</button>
                <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
            </div>
        </div>
    </form>
</div>
<!--添加和修改的弹出层结束-->

<script type="text/javascript" th:src="@{/layui/layui.js}"></script>
<script type="text/javascript">
    var tableIns;
    layui.use(['jquery', 'form', 'table', 'layer'], function () {
        var $ = layui.jquery;
        var form = layui.form;
        var table = layui.table;
        var layer = layui.layer;

        //加载数据
        tableIns = table.render({
            elem: '#providerTable'
            , url: '/provider/loadAllProvider'
            , toolbar: '#providerToolBar' //开启头部工具栏，并为其绑定左侧模板
            , title: '供应商数据表'
            , height: 'full-120'
            , page: true
            , cols: [ [
                {type:'checkbox',align:'center'}
                , {field: 'id', title: 'ID', align: 'center', width: "80"}
                , {field: 'providername', title: '供应商名称', align: 'center', width: '120'}
                , {field: 'zip', title: '邮编', align: 'center', width: '120'}
                , {field: 'address', title: '供应商地址', align: 'center', width: '120'}
                , {field: 'telephone', title: '供应商电话', align: 'center', width: '120'}
                , {field: 'connectionperson', title: '联系人', align: 'center', width: '120'}
                , {field: 'phone', title: '联系人电话', align: 'center', width: '120'}
                , {field: 'bank', title: '开户行', align: 'center', width: '120'}
                , {field: 'account', title: '账号', align: 'center', width: '120'}
                , {field: 'email', title: '邮箱', align: 'center', width: '120'}
                , {field: 'fax', title: '传真', align: 'center', width: '120'}
                , {
                    field: 'available', title: '是否可用', align: 'center', width: '200', templet: function (d) {
                        return d.available == 1 ? '<font color=blue>可用</font>' : '<font color=red>不可用</font>';
                    }
                }
                , {fixed: 'right', title: '操作', toolbar: '#providerRowBar', align: 'center', width: '200'}
            ] ]
            , done: function (res, curr, count) {
                //如果是异步请求数据方式，res即为你接口返回的信息。
                //如果是直接赋值的方式，res即为：{data: [], count: 99} data为当前页数据、count为数据总长度
                console.log(res);
                //得到当前页码
                console.log(curr);
                //得到数据总量
                console.log(count);
                if (res.data.length == 0 && curr != 1) {
                    tableIns.reload({
                        page: {
                            curr: (curr - 1),
                        }
                    });
                }
            }
        });
        //模糊查询
        form.on("submit(doSearch)", function (data) {
            tableIns.reload({
                where: data.field,
                page: {
                    curr: 1
                }
            });
            return false;
        });

        //监听工具条的事件
        table.on('toolbar(providerTable)', function (obj) {
            switch (obj.event) {
                case 'batchDelete':
                    batchDelete();
                    break;
                case 'add':
                    openAddLayer();
                    break;
            }
            ;
        });
        //监听工具条的事件
        table.on('tool(providerTable)', function (obj) {
            var data = obj.data;
            switch (obj.event) {
                case 'update':
                    openUpdateProviderLayer(data);
                    break;
                case 'delete':
                    deleteInfo(data);
                    break;
            }
            ;
        });

        //打开修改的弹出层
        function openUpdateProviderLayer(data) {
            mainIndex = layer.open({
                type: 1,
                content: $('#addOrUpdateDiv'),
                area: ['800px', '550px'],
                title: '修改供应商',
                success: function () {
                    $("#dataFrm")[0].reset();
                   form.val("dataFrm",data);
                    url = "/provider/updateProvider";
                }
            });
        }

        var mainIndex;

        //打开添加或修改弹出层
        function openAddLayer() {
            mainIndex = layer.open({
                type: 1,
                skin: 'layui-layer-molv',
                content: $('#addOrUpdateDiv'),
                area: ['800px', '550px'],
                title: '添加供应商',
                success: function () {
                    $("#dataFrm")[0].reset();
                    url = "/provider/addProvider";
                }
            });
        }

        form.on("submit(doSubmit)", function (data) {
            //表单序列化
            // var data = $("#dataFrm").serialize();
            $.post(url, data.field, function (res) {
                if (res.code == 200) {
                    tableIns.reload();
                }
                layer.msg(res.msg);
                layer.close(mainIndex);
            });
            return false;
        });
        //批量删除
        function batchDelete() {
            //得到选中行
            var checkStatus = table.checkStatus("providerTable");
            var dataLength = checkStatus.data.length;//获取选中行的长度
            var data = checkStatus.data;//获取选中的行数的数据
            if (dataLength > 0) {
                //需要添加提示语句
                layer.confirm('你确定要删除这些供应商数据吗?', {icon: 3, title: '提示'}, function (index) {
                    var ids = "";
                    $.each(data, function (index, item) {
                        if (index == 0) {
                            ids += "ids=" + item.id;
                        } else {
                            ids += "&ids=" + item.id;
                        }
                    });
                    $.post("/provider/batchDeleteProvider", ids, function (res) {
                        if (res.code == 200) {
                            tableIns.reload();
                        }
                        layer.msg(res.msg);
                    })
                    layer.close(index);
                });
            } else {
                layer.msg("请选中操作行");
            }
        };
        //删除
        function deleteInfo(data) {
            //需要添加提示语句
            layer.confirm('你确定要删除【' + data.providername + '】这个供应商吗?', {icon: 3, title: '提示'}, function (index) {
                $.post("/provider/deleteProvider", {id: data.id}, function (res) {
                    if (res.code == 200) {
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                });
                layer.close(index);
            });
        }
    });


</script>

</body>
</html>